File: /var/www/html/owlcrm/app/Http/Controllers/admin/RoleController.php
<?php
namespace App\Http\Controllers\admin;
use App\Models\SuperRole;
use Yajra\DataTables\Facades\DataTables;
use Validator;
use Illuminate\Validation\Rule;
use App\Http\Controllers\Controller;
use App\Models\AdminSuperRoles;
use App\Models\Module;
use App\Models\SuperRolePermission;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class RoleController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index(Request $request)
{
if ($request->ajax()) {
$search_keyword = '';
$request_data = $request->all();
if ($request->has('search_keyword')) {
$search_keyword = $request->search_keyword;
}
// avoid zero column as it's checkbox so we can't sort by it
if ($request->has('order') && $request->order[0]['column'] != 0) {
$sort_column_number = $request->order[0]['column'];
$sort_column_dir = $request->order[0]['dir'];
$sort_column_key = $request->columns[$sort_column_number]['data'];
}
$main_query = SuperRole::query();
$query = $main_query;
if (!empty($search_keyword)) {
$query = $query->where('name', 'LIKE', '%' . $search_keyword . '%');
}
if (!empty($sort_column_key)) {
$query = $query->orderBy($sort_column_key, $sort_column_dir);
} else {
$query = $query->latest();
}
$data = $query->get();
$count_total = $main_query->count();
$count_filter = $count_total;
return DataTables::of($data)
->addColumn('name', function ($row) {
return $row->name;
})
->addColumn('description', function ($row) {
return $row->description;
})
->addColumn('action', function ($row) {
return view('admin.roles.partially.delete', compact('row'));
})
->rawColumns(['action'])
->with([
"recordsTotal" => $count_total,
"recordsFiltered" => $count_filter,
])
->make(true);
}
return view('admin.roles.index');
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
$modules = Module::with('permissions')->get();
return view('admin.roles.create', ['modules' => $modules]);
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
$validator = Validator::make($request->all(), [
'name' => ['required', 'string', 'unique:' . SuperRole::class],
'description' => 'required|string',
]);
if ($validator->fails()) {
return redirect()->back()->withErrors($validator)->withInput();
}
DB::beginTransaction();
try {
$role = new SuperRole();
$role->name = $request->input('name');
$role->description = $request->input('description');
$role->save();
$permissions = $request->input('permission');
if (count($permissions)) {
foreach ($permissions as $permission) {
$role_permission = new SuperRolePermission();
$role_permission->role_id = $role->id;
$role_permission->permission_id = $permission;
$role_permission->save();
DB::commit();
}
}
return redirect()->route('roles.index')->with('success', 'Role added Successfully');
} catch (\Exception $e) {
DB::rollback();
return response()->json(['success' => false, 'message' => $e->getMessage()]);
}
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id)
{
$role = SuperRole::with('rolePermissions')->find($id);
$role_permission = [];
if (count($role->rolePermissions)) {
$role_permission = $role->rolePermissions->pluck('permission_id')->toArray();
}
$modules = Module::with('permissions')->get();
if (isset($role)) {
return view('admin.roles.edit', ['role' => $role, 'modules' => $modules, 'role_permission' => $role_permission]);
} else {
return back()->with('error', 'Role does not exist');
}
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, string $id)
{
$validator = Validator::make($request->all(), [
'name' => ['required', 'string', Rule::unique('super_roles')->ignore($id)],
'description' => 'required|string',
]);
if ($validator->fails()) {
return redirect()->back()->withErrors($validator)->withInput();
}
DB::beginTransaction();
try {
$role = SuperRole::find($id);
if (isset($role)) {
$role->name = $request->input('name');
$role->description = $request->input('description');
$role->save();
$permissions = $request->input('permission');
if (count($permissions)) {
SuperRolePermission::where('role_id', $id)->delete();
foreach ($permissions as $permission) {
$role_permission = new SuperRolePermission();
$role_permission->role_id = $role->id;
$role_permission->permission_id = $permission;
$role_permission->save();
DB::commit();
}
}
return redirect()->route('roles.index')->with('success', 'Role has been updated successfully.');
} else {
return back()->with('error', 'Role not found.');
}
} catch (\Exception $e) {
DB::rollback();
return response()->json(['success' => false, 'message' => $e->getMessage()]);
}
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
$role = SuperRole::find($id);
if (isset($role)) {
$role->delete();
SuperRolePermission::where('role_id', $id)->delete();
// for delete role_id in AdminSuperRoles migration
$adminSuperRole = AdminSuperRoles::where('role_id', $id)->delete();
return redirect()->back()->with('success', 'Role has been deleted successfully.');
} else {
return back()->with('error', 'Role not found.');
}
}
}